package com.huike.web.controller.review;


import com.github.pagehelper.Page;
import com.github.pagehelper.PageHelper;
import com.huike.common.core.controller.BaseController;
import com.huike.common.core.domain.AjaxResult;
import com.huike.common.core.page.TableDataInfo;
import com.huike.review.pojo.Review;
import com.huike.review.service.ReviewService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.DeleteMapping;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.List;

/**
 * 该Controller主要是为了复习三层架构以及Mybatis使用的，该部分接口已经放开权限，可以直接访问
 * 同学们在此处编写接口通过浏览器访问看是否能完成最简单的增删改查
 */
@RestController
@RequestMapping("/review")
public class MybatisReviewController extends BaseController {

    @Autowired
    private ReviewService reviewService;

    /**=========================================================新增数据============================================*/
    @GetMapping("/saveData/{name}/{age}/{sex}")
    public AjaxResult saveData(@PathVariable String name, @PathVariable Integer age, @PathVariable String sex){
        int count = reviewService.saveData(name, age, sex);
        return toAjax(count);
    }

    /**=========================================================删除数据=============================================*/
    @DeleteMapping("remove/{id}")
    public AjaxResult deleteData(@PathVariable Integer id){
        int count = reviewService.deleteData(id);
        return toAjax(count);
    }
    /**=========================================================修改数据=============================================*/

    @PostMapping("update")
    public AjaxResult updateData(@RequestBody Review review){
        int count = reviewService.updateData(review);
        return toAjax(count);
    }
    /**=========================================================查询数据=============================================*/
    @GetMapping("getById")
    public AjaxResult getById(Integer id){
        Review review = reviewService.getById(id);
        return AjaxResult.success(review);
    }

    @GetMapping("getDataByPage")
    public TableDataInfo getDataByPage(){

        return getDataTablePage(reviewService.getAll());
    }
}